草庐IT

mongodb - sql中组concat的模拟

全部标签

go - 如何将引用列表传递给 sql Scan 函数中的结构属性以自动执行该过程?

我有一个这种形式的结构,我也添加了方法。typeUserstruct{Idint64EmailstringUsernamestringGeonameIdint64BirthdatestringHashstringActiveImagestringAboutstringVerifiedboolNotificationboolJoinedint64LastActivityint64Ipv4int64Deletedbool}但每次我进行查询时,我都会手动将该查询的结果分配给这些不是很干的属性。每次我在数据库中添加一个新列时,我都必须手动更改大量代码行,这不是很理想。我的方法有:funcByE

mongodb - 使用 go 在 mongodb 中复制 Id

我正在尝试使用Mongodb在Go中编写一个简单的网络应用程序。我创建了一个简约的简单模型/Controller设置。我可以使用POST和url"/user"以及诸如'{"pseudo":"bobby1"}'之类的数据来创建新用户。用户已创建。但是,当查看Mongodbshell内部时,我得到:{"_id":ObjectId("5616d1ea56ca4dbc03bb83bc"),"id":ObjectId("5616d1ea5213c64824000001"),"pseudo":"bobby2"}“id”字段来self的结构,“_id”字段来自Mongodb。通过查看不同的示例代码,

Mongodb 对例程的查询会产生巨大的堆栈跟踪

我正在对go程序中的api进行大量网络调用,结果存储在数据库中(使用mgo)。api调用是在单独的go例程上完成的。在其他例程中,我会在更新数据库之前从数据库中提取信息并对其进行处理。当数据被放回时,会设置一个标志,以便知道该数据已经过后处理,因此当程序向数据库请求另一个条目以进行后处理时,数据库会返回一个标志complete设置为false。当标志设置为true时,go例程将关闭:wg.done()。一切都很好,我有很多打印输出告诉我程序是如何进行的,但是在运行结束时我得到一个包含很多相同内容的巨大堆栈跟踪:goroutine56731[sleep]:time.Sleep(0x12a

sql - 将数据库初始化为全局变量

将数据库初始化为全局变量是个好主意吗?能行吗?我正在考虑类似的事情:funcMustDB(d*sql.DB,errerror)*sql.DB{iferr!=nil{log.Panic(err)}returnd}//whatIdon'tknow-ishowtocalldb.Close()//usernameandpasswordcanalsobereadsimilarwayvardb*DB=MustDB(db.Open(...))funcMustPrepare(db*sql.DB,querystring)*sql.Stmt{res,err:=sql.Prepare(db,query)if

mongodb - Golang,mgo 为用户更新详细信息

我在更新mongo数据库上的用户时遇到了一些问题。基本上我想通过用户名选择用户而不是编辑其详细信息。我正在使用GorillaMux和mgo连接MongoDB。代码如下:funcViewUserHandler(whttp.ResponseWriter,r*http.Request){vars:=mux.Vars(r)username:=vars["username"]session,err:=mgo.Dial("mongodb://DATABASE_URL")iferr!=nil{panic(err)}defersession.Close()session.SetMode(mgo.Mon

mongodb - 如何将 BSON _Id 分配给 cookie(Go,Mongodb)

我正在尝试创建一个gocookie。我想从Mongodb分配Id以存储在Cookie中。但是在编译时出现如下错误:-“结构文字中的未知http.Cookie字段‘Id’”以下是我的代码:-getUser:=user.CheckDB()expiration:=time.Now().Add(365*24*time.Hour)//TheErrorisCausedbytheNextLinecookie:=http.Cookie{Id:getUser[0].Id,Name:getUser[0].Email,Value:getUser[0].Password,Expires:expiration}

unit-testing - 我如何在测试中模拟 Go 函数?

我在StackOverflow上阅读了一些关于如何模拟time.Now()等函数的问题。解决方案似乎是编写一个实现特定接口(interface)的结构,然后在测试中传入该模拟。有更好的方法吗?由于在Golang中没有足够好的依赖注入(inject)容器实现,我不想手动传递结构,或者创建一个内部只有这样的结构:func(sMyStruct)Now(){returntime.Now()}因为,首先,我无法测试这个函数。当你处理其中没有变量的一行时,它可能什么都不是,但我有一个连接到TCP端口的函数。做这样的事情需要我为它使用的所有东西创建适配器(例如net.Dial()、time.Now(

sql - 使用 Postgres 时为 "Operator does not exist: integer =?"

我在go的database/sql包提供的QueryRow方法中调用了一个简单的SQL查询。import("github.com/codegangsta/martini""github.com/martini-contrib/render""net/http""database/sql""fmt"_"github.com/lib/pq"))typeUserstruct{Namestring}funcShow(db*sql.DB,paramsmartini.Params){id:=params["id"]row:=db.QueryRow("SELECTnameFROMusersWHERE

mongodb - 如何使用go在mongodb中插入嵌套结构的多个值

我正在尝试使用golang在mongodb中插入带有嵌套结构的多个值......就像这样{"_id":ObjectId("56b879528d04effa4ae2de2c"),"task_content":"Sometext","priority":"2","deadline":{"start_time":ISODate("2009-04-04T00:00:00Z"),"end_time":ISODate("2009-05-04T00:00:00Z")},"users":{"u_status":"Completed","u_name":john_smith,"u_status":"Co

mongodb - 按给定示例中的字段名称更新 mongo 事务

我正在使用labix作为驱动程序,我想对几个集合进行交易,我找到了链接http://blog.labix.org/2012/08/22/multi-doc-transactions-for-mongodb我想更新集合Owner和Employer不是通过Id而是通过集合中的Name字段。我怎样才能做到这一点(简单的切换Id和Name不起作用)。runner:=txn.NewRunner(tcollection)ops:=[]txn.Op{{C:"accounts",Id:"aram",//NameAssert:M{"balance":M{"$gte":100}},Update:M{"$i